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(54) SYSTEM LSI AND POWER MANAGEMENT METHOD 

(57)Abstract: 

PROBLEM TO BE SOLVED: To provide a system LSI 
preventing the deterioration of performance due to the 
execution of the useless sleep of a CPU, and sharply 
improving a low power consumption effect. 
SOLUTION: This system LSI is provided with one or plural 
hardware modules M 1 -Mm for executing prescribed 
processing and a CPU 1 1 for controlling the operation of the 
hardware modules according to a program. This system LSI is 
also provided with a power management device 20 for 
controlling the stop and restar of clock supply to the CPU 1 1 . 
That is, the CPU 1 1 is provided with a means for executing a 
sleep instruction for operating the stop of the clock supply to 
the CPU 1 1 . The power management device 20 stops the clock 
supply to the CPU 1 1 based on the execution of the sleep 
instruction by the CPU 1 1 , and restarts the clock supply to the 
CPU 1 1 at the time of receiving the end of the processing of 
the hardware modules. 
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* NOTICES * 

Japan Patent Office is not responsible for any 
damages caused by the use of this translation. 

1. This document has been translated by computer. So the translation may not reflect the original 
precisely. 

2 **** s hows the word which can not be translated. 
3. In the drawings, any words are not translated. 



CLAIMS 



[Claim(s)] 

[Claim 1] The system LSI characterized by forming the power management equipment which controls a 
halt and resumption of clock supply to Above CPU in the system LSI equipped with one or more 
hardware modules which perform predetermined processing, and CPU which controls operation of the 
aforementioned hardware module according to a program. 

[Claim 2] It is the system LSI according to claim 1 which prepares a means to execute the sleep 
instruction for stopping clock supply to Above CPU in Above CPU, and is characterized by making the 
aforementioned power management equipment the composition which stops the clock supply to Above 
CPU based on execution of the aforementioned sleep instruction by Above CPU. 
[Claim 3] The aforementioned power management equipment is a system LSI according to claim 2 
characterized by making it the composition which resumes the clock supply to Above CPU in response 
to the end of processing of the aforementioned hardware module. 

[Claim 4] The aforementioned sleep instruction is a system LSI according to claim 3 which has the 1 st 
field which specifies by the end of processing of which hardware module the clock supply to Above 
CPU is resumed, and is characterized by making the aforementioned power management equipment the 
composition which resumes the clock supply to Above CPU with reference to the content of the 1 st field 
of the above. 

[Claim 5] The aforementioned sleep instruction is a system LSI according to claim 4 which has the 2nd 
field which specifies the register which stored the value of the 1st field of the above, and is characterized 
by making the aforementioned power management equipment the composition which resumes the clock 
supply to Above CPU with reference to the content of the above 1st and the 2nd field. 
[Claim 6] The system LSI according to claim 2 to 5 characterized by making the routine in the 
aforementioned program used in order to wait for the end of processing of the aforementioned hardware 
module the composition automatically transposed to the aforementioned sleep instruction. 
[Claim 7] It is the system LSI according to claim 1 to 6 characterized by making it the composition 
which it has the memory connected to Above CPU, and the aforementioned power management 
equipment stops clock supply in the aforementioned memory at the time of a halt of the clock supply to 
Above CPU, and resumes clock supply in the aforementioned memory at the time of resumption of the 
clock supply to Above CPU. 

[Claim 8] The aforementioned memory is a system LSI according to claim 7 characterized by forming 
on the same chip as Above CPU, the aforementioned hardware module, and the aforementioned power 
management equipment. 

[Claim 9] To the sleep instruction which it performs [ instruction ] in CPU and stops supply of the clock 
to this CPU When the content which directs the conditions of the operating state of the hardware module 
for making supply of the clock to CPU resume is included and CPU executes the aforementioned sleep 
instruction After storing the aforementioned conditions in the register, when the signal which stops 
supply of the clock to CPU is generated and the operating state of a hardware module agrees with the 
aforementioned conditions stored in the aforementioned register The power management method 



http://www4.ipdl.jpo.go jp/cgi-bin/tran_web_cgi_ejje?u=http%3A%2F%2Fwww6.ipdl.jpo.go.". 3/13/03 



Page 2 of 2 

characterized by generating the signal which makes supply of the clock to CPU resume. 



[Translation done.] 
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CLAIMS 



[Claim(s)] 

[Claim 1] The system LSI characterized by forming the power management equipment 
which controls a halt and resumption of clock supply to Above CPU in the system LSI 
equipped with one or more hardware modules which perform predetermined 
processing, and CPU which controls operation of the aforementioned hardware module 
according to a program. 

[Claim 2] It is the system LSI according to claim 1 which prepares a means to execute 
the sleep instruction for stopping clock supply to Above CPU in Above CPU, and is 
characterized by making the aforementioned power management equipment the 
composition which stops the clock supply to Above CPU based on execution of the 
aforementioned sleep instruction by Above CPU. 

[Claim 3] The aforementioned power management equipment is a system LSI according 
to claim 2 characterized by making it the composition which resumes the clock supply 
to Above CPU in response to the end of processing of the aforementioned hardware 
module. 

[Claim 4] The aforementioned sleep instruction is a system LSI according to claim 3 
which has the 1st field which specifies by the end of processing of which hardware 
module the clock supply to Above CPU is resumed, and is characterized by making the 
aforementioned power management equipment the composition which resumes the 
clock supply to Above CPU with reference to the contents of the 1st field of the above. 
[Claim 5] The aforementioned sleep instruction is a system LSI according to claim 4 
which has the 2nd field which specifies the register which stored the value of the 1st 
field of the above, and is characterized by making the aforementioned power 
management equipment the composition which resumes the clock supply to Above CPU 
with reference to the contents of the above 1st and the 2nd field. 

[Claim 6] The system LSI according to claim 2 to 5 characterized by making the routine 
in the aforementioned program used in order to wait for the end of processing of the 
aforementioned hardware module the composition automatically transposed to the 
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aforementioned sleep instruction. 

[Claim 7] It is the system LSI according to claim 1 to 6 characterized by making it the 
composition which it has the memory connected to Above CPU, and the aforementioned 
power management equipment stops clock supply in the aforementioned memory at the 
time of a halt of the clock supply to Above CPU, and resumes clock supply in the 
aforementioned memory at the time of resumption of the clock supply to Above CPU. 
[Claim 81 The aforementioned memory is a system LSI according to claim 7 
characterized by forming on the same chip as Above CPU, the aforementioned 
hardware module, and the aforementioned power management equipment. 
[Claim 9] To the sleep instruction which it performs [ instruction ] in CPU and stops 
supply of the clock to this CPU When the contents which direct the conditions of the 
operating state of the hardware module for making supply of the clock to CPU resume 
are included and CPU executes the aforementioned sleep instruction After storing the 
aforementioned conditions in the register, when the signal which stops supply of the 
clock to CPU is generated and the operating state of a hardware module agrees with the 
aforementioned conditions stored in the aforementioned register The power 
management method characterized by generating the signal which makes supply of the 
clock to CPU resume. 

DETAILED DESCRIPTION 



[Detailed Description of the Invention] 
[0001] 

[The technical field to which invention belongs] this invention relates to the system LSI 
which carried CPU and one or more hardware modules on the chip, and the power 
management method of realizing the low-power-ization. 
[0002] 

[Description of the Prior Art] Generally, the conventional system LSI has the 
composition of having carried on the chip CPU111, two or more hardware modules M0, 
Ml, — , Mn, and the memory 112 that stores an instruction and data, as shown in 

drawing 20 . CPU111 issues the processing instruction other than the processing which 
itself performs to hardware modules MO-Mn. The operating state of hardware modules 
MO-Mn, i.e., execution of the processing which was performing given processing or was 
given, is completed, and the operating state whether the following processing instruction 
is waiting or to be among sleep is supervised by CPU111. 

[0003] About low-power-izing of this system LSI, the following technology is proposed, 
for example. (1) CPU111 stops supply of the clock to the hardware modules MO-Mn, 
and attains low-power-ization in the period when some hardware modules MO-Mn do 
not need to be operating by changing these hardware modules MO-Mn into a sleep state. 
(2) If a hardware module M0 - Mn itself end the given processing, low-power-ization 
will be attained by changing into a sleep state automatically. 
[0004] 

[Problem(s) to be Solved by the Invention] However, about low-power-izing of the 
conventional system LSI, the power consumed by CPU occupies many of power 
consumed with the whole chip, and has been a technical problem with important low- 



power-izing of CPU. 

[0005] From such a viewpoint, the following can be considered as the technique of 
changing CPU111 into a sleep state. There is a period when CPU111 cannot perform the 
next processing until hardware modules MO-Mn end the processing to which 
predetermined was given fr m relations, such as data dependence, like, when CPU111 
performs the next processing as a period which can change CPU111 into a sleep state 
using the result of the processing which hardware modules MO-Mn performed, for 
example. Although CPU111 can be changed into a sleep state between the latency times 
to the processing end of such hardware modules MO-Mn, the method poses a problem. 
[0006] In the case where CPU111 is changed into a sleep state with hardware control, 
there is a possibility of causing the degradation by execution of useless sleep and the fall 
of the power consumption curtailment effect It is because sleep may be carried out 
although it must be able to carry out the Wake rise immediately after changing CPU111 
into a sleep state or CPU111 can be changed into a sleep state, since CPU111 cannot 
predict operation which should be performed to a degree. Moreover, when it is going to 
control by hardware strictly the timing which carries out sleep, there is also an 
overhead of area and power consumption or a problem of becoming large, by the 
hardware. 

[0007] On the other hand, the period which changes CPU111 into a sleep state for 
CPU111 sleep and when carrying out the Wake rise is beforehand estimated by 
software control, and the Wake rise is carried out, after pointing to the period by sleep 
instruction and changing into a sleep state. However, when many sleep periods are 
estimated, sleep will be carried out to a useless period and degradation will be caused 
after all. On the contrary, when it estimates few, a clock will be supplied in the period 
which may be carrying out sleep in practice, and there is a problem that the power 
consumption curtailment effect falls. 

[0008] Made in order that this invention might solve the conventional trouble like ****, 
the purpose is offering the system LSI and the power management method of raising a 
low-power-ized effect sharply, avoiding the degradation by execution of sleep with 
useless CPU. Moreover, the other purposes are offering the system LSI which can attain 
the increase in efficiency of the low-power design in a system LSI. 
[0009] 

[Means for Solving the Problem] In order to attain the above-mentioned purpose, the 
feature of the system LSI which is invention according to claim 1 is in the system LSI 
equipped with one or more hardware modules which perform predetermined 
processing, and CPU which controls operation of the aforementioned hardware module 
according to a program to have formed the power management equipment which 
controls a halt and resumption of clock supply to Above CPU. 
[0010] In invention of the claim 1 above-mentioned publication, the feature of the 
system LSI which is invention according to claim 2 prepares a means execute the sleep 
instruction for stopping clock supply to Above CPU in Above CPU, and the 
aforementioned power management equipment is in it for having carried out to the 
composition which stops the clock supply to Above CPU based on execution of the 
aforementioned sleep instruction by Above CPU. 

[0011] In invention of the claim 2 above-mentioned publication, the aforementioned 
power management equipment has the feature of the system LSI which is invention 
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according to claim 3 in having made it the composition which resumes the clock supply 
to Above CPU in response to the end of processing of the aforementioned hardware 
module. 

[0012] In invention of the claim 3 above-mentioned publication, the aforementioned 
sleep instruction has the 1st field which specifies by the end of processing of which 
hardware module the clock supply to Above CPU is resumed, and the feature of the 
system LSI which is invention according to claim 4 is in the aforementioned power 
management equipment for having carried out to the composition which resumes the 
clock supply to Above CPU with reference to the content of the 1st field of the above. 
[0013] Having the 2nd field where the feature of the system LSI which is invention 
according to claim 5 specifies the register with which the aforementioned sleep 
instruction stored the value of the 1st field of the above in invention of the claim 4 
above-mentioned publication, the aforementioned power management equipment is to 
have made it the composition in which the clock supply to Above CPU is resumed with 
reference to the content of the above 1st and the 2nd field. 

[0014] The feature of the system LSI which is invention according to claim 6 is in the 
above-mentioned claim 2 or invention according to claim 5 to have made the routine in 
the aforementioned program used in order to wait for the end of processing of the 
aforementioned hardware module the composition automatically transposed to the 
aforementioned sleep instruction. 

[0015] The feature of the power management method which is invention according to 
claim 7 To the sleep instruction which it performs [ instruction ] in CPU and stops 
supply of the clock to this CPU When the content which directs the conditions of the 
operating state of the hardware module for making supply of the clock to CPU resume 
is included and CPU executes the aforementioned sleep instruction It is in generating 
the signal which stops supply of the clock to CPU, after storing the aforementioned 
conditions in a register, and generating the signal which makes supply of the clock to 
CPU resume, when the operating state of a hardware module agrees with the 
aforementioned conditions stored in the aforementioned register. 
[0016] 

[Embodiments of the Invention] Hereafter, the gestalt of operation of this invention is 
explained with reference to a drawing. 

[0017] [1st operation gestalt] drawing j is the Wock diagram showing the composition of 

the system LSI concerning the 1st operation gestalt of this invention. 
[0018] The fundamental composition of this system LSI has the composition of having 
added the power management module 20 which had sleep and a function for carrying 
out the Wake rise for CPU11, in the same system LSI ( drawing 20 ) as the former 
equipped with CPU11, the hardware modules MO-Mn of plurality (one [ or ]), and the 
memory 12 that stores a program and data. 

[0019] although a clock is supplied to CPU11 through this power management module 
20, a partial circuit with the need of always supplying the clock is resembled as usual, 
and a clock is supplied to it Furthermore, an addition and change of a function are 
added to CPU11 so that the sleep instruction for changing CPU11 into a sleep state can 
be decoded and executed in addition to the conventional instruction set. 
[0020] In addition t the operation code OP showing a sleep instruction, the instruction 
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code of a sleep instruction gives the Wake rise module field WU and the condition field 
CO, as shown in drawing 2 . The Wake rise module field WU is the field which specifies 
whether the Wake rise of CPU11 is carried out, when processing of which hardware 
modules MO-Mn is completed (the hardware module specified to be this appearance is 
hereafter called Wake rise module). It enables it to specify one or more hardware 
modules to be the Wake rise module fields WU by giving the bit corresponding to each 
hardware module. The condition field CO will specify (it is hereafter called OR 
conditions) for whether the Wake rise of CPU11 is carried out, if either (it being 
hereafter called AND conditions) or those processings end whether the Wake rise of 
CPU11 will be carried out if all of those processings are completed when two or more 
modules in the Wake rise module field WU are specified. 

[0021] For example, in a system LSI with five hardware modules MO, Ml, M2, M3, and 
M4, when processing of both hardware modules MO and M2 is completed, the sleep 
instruction in the case of carrying out the Wake rise of CPU11 comes to be shown in 

drawing 3 . 

[0022] However, bit width of face of an instruction is made into 32 bits, and 1 bit is 
assigned to the condition field CO and, in the case of AND conditions, in the case of "0" 
and OR conditions, it is made into "1." Moreover, the Wake rise module field WU 
corresponded to hardware modules M0-M4 sequentially from the least significant bit, 
and when the bit corresponding to each hardware modules M0-M4 was "1", the 
hardware module should be specified as a Wake rise module. 
[0023] A sleep instruction uses it in the program in the conventional system LSI, 
replacing with the routine (it is hereafter called the waiting routine for a hardware 
processing end) only for waiting for the end of processing of a hardware module. For 
example, suppose that there was a routine as shown in draWing 4 by the program of the 

conventional system LSI. Here, mfc is taken as the instruction which loads the content 
of the register for hardware module control to a general-purpose register. Moreover, by 
state's being the register which stores the operating state of a hardware module, and 
corresponding to hardware modules M0-M4 from a least significant bit, respectively, if 
a certain bit is "1", the hardware module corresponding to the bit shall express that 
processing is under execution. 

[0024] This waiting routine for a hardware processing end performs the following 
processings. First, the content of Sstate is loaded to a general-purpose register r2. Next, 
only the operating state of hardware modules Ml and M3 is extracted by performing 
the AND operation of "r2" and "0x0005." Then, comparison of "r2" and "rO (for the 
content, "0" is always a register)" is performed, and if both are not equal, it branches to 
the instruction which a label called Loop attached, i.e., the first mfc instruction. Since it 
is that CPU11 does not perform the next processing until processing of hardware 
modules M0 and M2 ends this, the sleep of CPU11 can be carried out in the meantime. 
Then, by replacing this routine by one sleep instruction of d raw j ng 3 f w hile waiting for 

the processing end of hardware modules M0 and M2, the sleep of CPU11 is carried out 
Power consumption is not only reducible, but program length can be shortened by this. 

[0025] D raw i ng 5 i s the block diagram showing the composition of the power 
management module 20. This power management module 20 consists of a comparator 
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21, the Wake rise module register 22, a m dule state flag register 23, a sleep control flip- 
flop 24, and the OR gate 25. 

[0026] The sleep control flip-flop 24 is a flip-flop for controlling supply of the clock to 
CPU11, and reset-signal RTF is inputted for the set signal STF from a comparator 21 
from CPU11 again. 

[0027] The input of the OR gate 25 is the clock creatine kinase (it is hereafter called a 
main clock) currently supplied to CPU11 with the output OUT of the sleep control flip- 
flop 24, and the composition of the conventional system LS 1, and an output serves as 
the clock CLK supplied to CPU11. The module state flag register 23 is a register for 
supervising the operating state of a hardware module, and is giving the bit 
corresponding to each hardware module. CPU11 sets the value of this register and each 
hardware module resets it When CPU11 of the conventional system LSI has the 
register which has an equivalent function, it can substitute for this register. The Wake 
rise module register 22 is a register which stores the value of the Wake rise module field 
WU in sleep instruction code, and when CPU11 decodes / executes a sleep instruction, it 
transmits a storing value. A comparator 21 is a circuit for detecting the timing which 
carries out the Wake rise of CPU11. The value of the module state flag register 23, the 
value of the Wake rise module register 22, the value of the condition field CO in sleep 
instruction code, and interrupt signal BR are inputted, and reset-signal RTF is 
outputted to the sleep control flip-flop 24 with those values. 
[0028] Operation of the system LSI of this operation gestalt is explained. 
[0029] When an initial state, i.e., a system LSI, is reset, interrupt signal BR (reset 
interruption) is inputted into a comparator 21. Since the sleep control flip-flop 24 is 
reset by this and the output OUT of the sleep control flip-flop 24 is set to "0" by it, 
Clock CLK is supplied to CPU11. CPU11 sets the bit corresponding to the hardware 
module in the module state flag register 23 at the same time it gives a processing 
instruction to a certain hardware module. 

[0030] Next, execution of a sleep instruction transmits the value of the Wake rise 
module field WU in sleep instruction code, and the value of the condition field CO to the 
Wake rise module register 22 and comparator 21 of the power management module 20, 
respectively. Moreover, the sleep control flip-flop 24 is set and the output OUT is set to 
"1." 

[0031] If the output OUT of the sleep control flip-flop 24 which is one of the inputs of 
the OR gate 25 is set to "1", the output CLK of the OR gate 25, i.e., the clock signal to 
CPU11, will not be concerned with the value of the main clock creatine kinase which is 
another input, but it will be set to "1." That is, since it means that supply of the clock 
CLK to CPU11 was stopped, CPU11 will be in a sleep state. 

[0032] Each hardware modules M0-M4 reset the bit corresponding to the hardware 
module of the module state flag register 23, after the given processing is completed. The 
comparator 21 is always comparing the value of the module state flag register 23 and 
the Wake rise module register 22, and when the result satisfies the conditions given in 
the condition field CO of sleep instruction code, it outputs reset-signal RTF to the sleep 
control flip-flop 24. Moreover, when interrupt signal BR is inputted, it is not concerned 
with a comparison result but reset-signal RTF is outputted. 

[0033] If the sleep control flip-flop 24 is reset, since the output OUT of this flip-flop 24 
will be set to "0", the main clock creatine kinase which is another input of the OR gate 



25 is transmitted to the output CLK of the OR gate 25 as it is. Supply of the clock CLK 
to CPU11 is resumed by this, and CPU11 carries out the Wake rise by it. 
[0034] The system LSI which carried three hardware modules MO, Ml, and M2 as 
shown in drawing 6 fs mad£ int0 a „ example> and above _ mentioiied operation is 
explained still more concretely. 

[0035] D ra wiiig 7 is the circuit diagram showing the example of composition of the 
comparator 21 in the power management module 20 in this example, each bit of the 
module state flag register 23 here corresponding to hardware modules M0, Ml, and M2, 
and the Wake rise module register 22 - respectively (SO, SI, S2) - and (W0, Wl, W2) 
** — it carries out It is shown that the hardware module corresponding to them is 
processing performing (SO, SI, S2) when a value is "1", and (W0, Wl, W2) shall show 
that the hardware module corresponding to them was specified as a Wake rise module, 
when a value is "1." 

[0036] If a processing instruction is taken out from CPU11 to a hardware module Ml, it 
will become = (SO, SI, S2) (1, 0, 0). Moreover, if a processing instruction is also given to 
a hardware module M2 while the hardware module M0 is performing processing, it will 
become = (SO, SI, S2) (1, 0, 1). Then, if the sleep instruction of drawing 8 to which the 

sleep of CPU11 is carried out till the processing end of both hardware modules M0 and 
M2 is decoded / executed, "0" as which (1, 0, 1) express AND conditions in a 
comparator 21 to (W0, Wl, W2) will be transmitted first, respectively. 
[0037] Next, CPU11 will be in a sleep state by inputting the set signal STF into the sleep 
control flip-flop 24. Within the comparator 21, the value of (SO, SI, S2), and (W0, Wl, 
W2) is compared by the combinational circuit (AND condition block 21a, OR condition 
block 21b). Since AND conditions are specified by the sleep instruction, the output of 
AND condition block 21a is chosen by multiplexer 21c. 

[0038] In AND condition block 21a, the bit corresponding to the hardware modules M0, 
Ml, and M2 of the module state flag register 23 and the Wake rise module register 22 is 
inputted into NAND gates AC0, AC1, and AC2, respectively. (SO, SI, S2) The output of 
AND-gate AC3 to which these values are considered as an input at the time of = (1, 0, 1) 
and = (W0, Wl, W2) (1, 0, 1) since the outputs of NAND gates AC0, AC1, and AC2 are 
"0", "1", and "0", respectively is set to "0." Since it is W1=0, it is not concerned with 
the value of SI, i.e., the operating state of a hardware module Ml, but the output of 
NAND gate AC1 is always set to "1." That is, only the operating state of the hardware 
module specified as a Wake rise module influences the output of AND-gate AC3. 
[0039] Since the output of NAND gate AC2 is "0" even if processing of a hardware 
module M0 is completed, it is set to S0=0 and the output of NAND gate AC0 is set to 
"1", the output of AND-gate AC3 is still "0." If processing of a hardware module M2 is 
also ended and it is set to S2=0, the output of NAND gate AC2 will be set to "1." NAND 
gates AC0, AC1, and AC2 - if all outputs are set to "1", the output of AND-gate AC3 
will be set to "1" Since the output of AND-gate AC3 is chosen by multiplexer 21c, the 
output of multiplexer 21c is set to "1." Since it is the output of multiplexer 21c, and the 
input whose interrupt signal BR is 21d of OR gates, when interrupt signal BR is not 
inputted, the output of AND-gate AC3 is transmitted to the output which is 21 d of OR 
gates as it is. Since this becomes the output of a comparator 21, i.e., reset-signal RTF, 
when processing of both hardware modules M0 and M2 is completed, reset-signal RTF 
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is set to "1." If the sleep control flip-flop 24 is reset by this reset-signal RTF and the 
output OUT is set to "0" by it, the value of the main clock creatine kinase will be 
transmitted to the output of the OR gate 25 as it is, and supply of the clock CLK to 
CPU1 1 will be resumed. 

[0040] Next, the case where the sleep instruction of drawing 9 to which the s i ee p of 

CPU11 is carried out till the end of a hardware module MO or processing of M2 is 
executed is explained. 

[0041] Since OR conditions are specified by the sleep instruction, the output of OR 
condition block 21b is chosen by multiplexer 21c. In OR condition block 21b, the bit 
corresponding to M0, Ml, and M2 of the module state flag register 23 and the Wake 
rise module register 22 is inputted into the AND gates OC0, OC1, and OC2, 
respectively. However, the value by which the value of the module state flag register 23 
was reversed is inputted. (SO, SI, S2) The output of OR-gate OC3 to which these values 
are considered as an input at the time of = (1, 0, 1) and = (W0, Wl, W2) (1, 0, 1) since 
the outputs of the AND gates OC0, OC1, and OC2 are "0", "0", and "0", respectively is 
set to "0." since it is W1=0 - the value of SI, i.e., the operating state of a hardware 
module Ml, - not being concerned - the output of AND-gate OC1 - "0" - always - ** 
— it becomes That is, only the operating state of the hardware module specified as a 
Wake rise module influences the output of OR-gate OC3. 

[0042] If processing of a hardware module M0 is completed and it is set to S0=0, the 
output of AND-gate OC0 will be set to "1", and the output of OR-gate OC3 will also be 
set to "1" by this. This value lets multiplexer 21c and 21d of OR gates pass, and is 
outputted to the sleep control flip-flop 24 as a reset-signal RTF. 
[0043] When interrupt signal BR is inputted, regardless of the output of multiplexer 
21c, the output of 21 d of OR gates is set to "1", and reset-signal RTF will be outputted 
to the sleep control flip-flop 24. 

[0044] Here, although only AND conditions and OR conditions explained composition 
and operation for the conditions which carry out the Wake rise of CPU11, the circuit of 
a condition block is added and other condition logic can be realized by using two or 
more bits for the condition field CO of sleep instruction code. 

[0045] Moreover, even if it carries out the Wake rise of CPU11 or processing of which 
hardware module is completed by the processing end of a specific hardware module, in 
carrying out the Wake rise of CPU11, a comparator 21, the Wake rise module register 
22, and the module state flag register 23 become unnecessary. What is necessary is just 
to input into the sleep control flip-flop 24 by setting the result of the OR operation of the 
processing terminate signal from a hardware module, and interrupt signal BR to reset- 
signal RTF. The power management module 20 can be simplified by this. 
[0046] When interrupt signal BR was inputted and it changes into the state where there 
is a circuit, using reset-signal RTF being outputted to the sleep control flip-flop 24, it 
becomes possible to carry out the Wake rise of CPU11. For example, what is necessary 
is just to make it output interrupt signal BR, when a data bus changed into a 
predetermined state, the Wake rise of CPU11 was carried out, the circuit which 
supervises the state of a data bus is added and a data bus changes into the state. 
[0047] Although the composition which added the power management module 20 to the 
conventional system LSI explained with this operation form, this is for giving 
explanation easy and may include this function into CPU11. In this case, it is that a 
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clock is always supplied to the circuit equivalent to the Wake rise module register 22, 
the module state flag register 23, and the sleep control flip-flop 24, and same operation 
can be realized. 

[0048] Thus, with this operation form, since the timing to which the sleep of CPU11 is 
carried out was controlled by software (sleep instruction), it can determine when a 
programmer carries out the sleep of CPU11, and it becomes possible to avoid the 
degradation by execution of useless sleep. Furthermore, only a suitable period becomes 
possible [ carrying out sleep ] by controlling the Wake rise of CPU11 by hardware, 
without predicting a sleep period. It becomes possible to raise a low-power-ized effect 
sharply, this avoiding the degradation by execution of useless sleep. Moreover, since the 
power management module 20 which realizes these functions can be mounted by very 
easy hardware, its overhead of the area by this and power consumption is also small. 
[0049] Since the waiting routine for a hardware module processing end which consisted 
of two or more instructions is transposed to one sleep instruction, the amount of 
memory which is needed since a program is stored becomes small, and the number of 
instructions performed also becomes less than the conventional program. Furthermore, 
since instruction memory is not accessed while CPU is carrying out sleep, the sleep also 
of the instruction memory can be carried out in the meantime. The power consumption 
of instruction memory is also cut down by these things. 

[0050] The 2nd operation form of the [2nd operation form] this invention is explained 

with reference to j r(lwinn in 

drawing 10 , drawing n ? and ^ 

[0051] In the system LSI shown in drawing i with five hardware modules M0, Ml, M2, 
M3, and M4, the case where it is expressed with a flow chart as a part of program 
performed shows to draw i ng iq j s considered. Here, suppose that a processing 
instruction is taken out with processing 1.1, processing 1.2, processing 2.1, processing 
2.2, and processing 3 to hardware modules M0, Ml, M2, M3, and M4, respectively. 
Since the waiting routine for a hardware module processing end is after processing 3 is 
completed, by transposing this to a sleep instruction, the sleep of CPU11 is carried out 
and curtailment of power consumption is aimed at 

[0052] However, supposing it waits to complete processing of all hardware modules in 
which this routine was able to give the processing instruction in the performed 
processing, in the sleep instruction code of drawing 2 ? it is unrealizable. In the sleep 

instruction of d raw j ng 2 , since conditional branching occurs by this program to 
presuming the Wake rise instruction clearly, it is because the hardware module which 
has a processing instruction issued is not determined as 1 set. 

[0053] Then, the 2nd sleep instruction code shown in drawing n is introduced. This 

sleep instruction code consists of an operation code OP and the one register field RG. 
One certain register is specified in the register field RG. The contents equivalent to the 
value of the Wake rise module field WU in the sleep instruction code of £ rskyv i n g 2 and 

the condition field CO are stored in the register specified here. When decoding and 
executing this sleep instruction, the Wake rise of CPU11 is controlled by transmitting 
the value of the register directed in the register field RG to the power management 
module 20. 
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[0054] Next, how to change CPU1 1 into a sleep state is explained with reference to the 
flow chart of drawing 12 using this sleep instruction. 

[0055] The most significant bit of the register specified in the register field RG 
presupposes that it is equivalent to the condition field CO, and 5 bits is equivalent to the 
Wake rise module field WU from a least significant bit Moreover, suppose that a 
general-purpose register r8 is specified in a sleep instruction. 

[0056] In drawing 12 , first, before performing processing in connection with sleep 
operation, it initializes by substituting "0x0000" for "r8." After giving a processing 
instruction to a hardware module M0 in processing 1.1, an OR operation is performed 
for the value of "r8", and "0x0001." Similarly, after giving a processing instruction to 
hardware modules Ml, M2, M3, and M4 in processing 1.2, processing 2.1, processing 
2.2, and processing 3, the value of "r8" and the OR operation of "0x0002", "0x0004", 
"0x0008", and "0x0010" are performed, respectively, and the result is stored in "r8." If 
it is AND conditions and is "0x0000" and OR conditions before executing a sleep 
instruction in order to specify the value of the condition field CO, the OR operation of 
"0x8000" and "r8" is performed, respectively. 

[0057] When performing processing 1.1 and processing 2.1 and carrying out the Wake 
rise of CPU11 on AND conditions by doing in this way, the contents of "r8" are set to 
"0x0015", and sleep operation of carrying out the Wake rise of CPU11 according to the 
AND conditions of hardware modules M0 and M2 can be realized. 
[0058] In addition, since pipeline processing is carried out, there is a case where he 
wants to make the instruction preceded before a sleep instruction goes into the 
execution stage completed. For example, when accessing memory 12 by processing by 
CPU11 and loading/store instruction is left with the access demand from CPU11 coming 
out, it is the case where it becomes impossible ATASESU [ other modules ]. In this case, 
a number required before a sleep instruction of NOP instructions are inserted, and a 
sleep instruction is made to execute after the instruction is completed. 
[0059] the [ next, / the above 1st and ] — the sleep to CPU11 used for 2 operation forms 
and the order of the real way of the Wake rise processing are explained with reference 
to the flow chart of drawing 13 

[0060] First, CPU11 decodes the instruction executed next (Step Sll), and it judges 
whether it is the sleep instruction to which the sleep of CPU11 is carried out (Step S12). 
If it is a sleep instruction, the conditions for carrying out the Wake rise of CPU11 
directed by this instruction are stored in a register (Step S13). Furthermore, the signal 
which stops supply of the clock to CPU11 is generated, and CPU11 carries out sleep 
with this signal (Step S14). 

[0061] While CPU11 is carrying out sleep, after the processing under execution of a 
certain hardware module is completed, a processing terminate signal is generated (Step 
S15). It is judged whether the conditions which make the clock supply to stored CPU11 
resume were fulfilled (Step S16), if filled by the processing end of the hardware module, 
the signal which makes supply of the clock to CPU11 resume will be generated by it, 
and CPU11 will carry out the Wake rise by it (Step SI 7). 

[0062] the [ the [3rd operation form] above 1st and ] — with 2 operation forms, when 
CPU11 cannot perform the next processing until processing of a certain hardware 
module is completed, CPU11 is changed into a sleep state with software (sleep 
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instruction), and the Wake rise of CPU11 is carried out by the processing terminate 
signal from the hardware module In this case, the operation code OP to which the sleep 
instruction c de used expresses a sleep instruction, The Wake rise module field WU 
which specifies by the processing terminate signal from which hardware module the 
Wake rise of CPU11 is carried out, When two or more hardware modules in the Wake 
rise module field WU are specified, those AND conditions that will carry out the Wake 
rise of CPU11 if processing is all completed, And if ones of those processings is 
completed, it will consist of the condition field CO showing OR conditions which carry 
out the Wake rise of CPU11. the [ the above 1st and ] — with 2 operation forms, since 
such sleep instruction code was ungenerable with a compiler, there was fault that the 
waiting routine for a hardware module processing end had to be transposed to a sleep 
instruction by the help 

[0063] In order to cancel this fault, with the **** 3 operation gestalt, the function which 
transposes automatically the waiting routine for a hardware module processing end in 
the conventional program to the aforementioned sleep instruction is prepared. 
Hereafter, the technique is explained in detail. 

[0064] Drawing 14 is drawing showing an example of the waiting routine for a 
hardware module processing end in the program of a system LSI. 
[0065] In this drawing, the value of status-register state of a hardware module is first 
loaded to a general-purpose register r2 by mfc instruction. Here, each bit of status- 
register state will be set to "0", if a corresponding hardware module is performing 
processing and "1" and processing will be ended. 

[0066] Then, a mask is covered over the value loaded by andi instruction. Since the 3rd 
operand of an andi instruction is "0x0003", this has taken out only the operating state 
of the hardware module (hereafter referred to as M0 and Ml, respectively) 
corresponding to the 0th bit (LSB) of status-register state, and the 1st bit And a bne 
instruction performs comparison with the register rO which is always "0", and if the 
result is not equal, it already branches to the degree of-, and mfc2 instruction, and if 
equal, it will escape from the routine. That is, it will be called the routine for which it 
waits that processing of both hardware modules M0 and Ml ends this routine. 
[0067] Next, it considers transposing this routine to a sleep instruction. 
[0068] Since the Wake rise of CPU11 is carried out by the end of processing of 
hardware modules M0 and Ml in this example, the Wake rise module field WU of a 
sleep instruction is set to "0x0003." Moreover, if processing of all the hardware modules 
specified at both hardware modules Ml [ M0 and ] WU, i.e., the Wake rise module field, 
is completed, since the Wake rise of CPU11 will be carried out, the value of the 
condition field CO serves as AND conditions. Therefore, a corresponding sleep 
instruction comes to be shown in drawing 15 . Here5 as for the value of "111111" and 

the condition field CO, "0" and OR conditions set [ AND conditions ] the operation 
code OP showing a sleep instruction to "1." 

[0069] Another example of the waiting routine for a hardware module processing end is 

shown in drawing 16 m In th | s example, first, "0x0003" is substituted for the register r3, 
and this is used as a mask by the next and instruction of mfc2 instruction. When the 
value of status-register state over which the mask was covered is the same as r3 (i.e., 
when having ended neither of hardware modules M0 and Ml of the processings), 
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branching is materialized, and when it differs (i.e., when one processing of the hardware 
m dules MO or Ml is completed), it escapes from this routine. That is, this routine is a 
routine f r waiting to complete one pr cessing of the hardware modules MO r Ml. 
Therefore, when this routine is transposed to a sleep instruction, it comes to be shown in 

drawing 17 . Here, the value of the Wake rise module field WU is "0x0003" which 
shows hardware modules MO and Ml, and since the condition field CO carries out the 
sleep of CPU11 until one processing of the hardware modules MO or Ml is completed, it 
serves as OR conditions. 

[0070] In a compiler, a sleep instruction is automatically generable by transposing the 
procedure which generates such an instruction sequence to the procedure which 
generates a sleep instruction. 

[0071] Next, the procedure for transposing the waiting routine for a hardware module 
processing end to a sleep instruction is explained with reference to draw i n g jg and 

drawing 19 . 

[0072] In the flow chart of draw j ng ? a SO urce code is first changed into an assembly 
code with a compiler (Step S21). Next, a hardware module processing end **** routine 
is changed into a sleep instruction by filtering this (Step S22). When the changed 
assembly code assembles at the end, a machine language including a sleep instruction is 
generated (Step S23). 

[0073] A translation table is used for filtering at Step S22. The sleep instruction 
corresponding to the instruction sequence which has realized the waiting routine for a 
hardware module processing end, and its instruction sequence constructs a translation 
table, and it consists of ******* A constant and a variable express the operand of an 
instruction sequence. The example of the translation table for changing the instruction 

sequence of drawing 14 and drawing 15 fato a s , eep instruction at drawing J9 ig shown 

[0074] In draw in g 19 9 a declaration of a variable and a constant is made first. Here, 
state below Scons t, and rO, and and or are constants, and regl, reg2, imml, and imm2 
below $var are a variable. LABEL1 and LABE2 below $label are a special variable for 
the judgment with a branching place in agreement (it is hereafter called a label 
variable). The portion surrounded by Stable and Sendtable is the actual condition of a 
translation table, and below Sstream in this is the format of the sleep instruction which 
an instruction sequence and below Sformat change. 

[0075] Furthermore, the procedure of filtering is explained. The filter performs 
comparison with the instruction sequence of a translation table sequentially from the 
beginning of an assembly code. Comparison is performed as follows. First, it judges 
whether an operation code OP is in agreement. If in agreement, it will judge whether 
next an operand is in agreement. In this case, the operand given as a constant by the 
translation table compares as it is. When substituting the value of the operand of an 
assembly code in the case of the first comparison performed using the variable and 
performing comparison with the variable next at it, it compares with the operand given 
as a variable using the substituted value. If both are in agreement as a result of 
comparison, the instruction sequence in an assembly code will be replaced according to 
the format of the sleep instruction to which it was given by SformaL 
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[0076] When there is a hardware module processor-limited routine as shown in a 
certain acene pulley code at drawing 14 hereafter, the procedure at the time of changing 
this into a sleep instruction by the translation table shown in fi rsm ing 19 is explained 
concretely. 

[0077] Since "LABEL!:" appeared in the assembly code, the position of this label is 
stored. Next, since there is mfc2 instruction and this is in agreement with the instruction 
of the beginning of the instruction sequence in a translation table, the operand is 
compared. Since the first operand of the mfc2 instruction in a translation table is a 
variable of regl, the value r2 of the first operand of the mfc2 instruction in an assembly 
code is substituted for this. Since the second operand of mfc2 instruction of a translation 
table is a constant, it compares as it is. 

[0078] Since the mfc instruction of an operand corresponds, the next instruction is 
compared. Since both are in agreement by andi instruction, a first operand is 
compared. Since the first operand of an andi instruction of a translation table is a 
variable reg2, the first operand r2 of the andi instruction in an assembly code is 
substituted for this. 

[0079] Since the second operand of an andi instruction of a translation table is regl of 
existing appearance, it is compared using r2 previously substituted for this variable. 
"0x0003" is substituted for imml by comparison of the 3rd operand. In comparison of 
the next bne instruction, a second operand is the same. 

[0080] Since LABEL1 of the 3rd operand of a bne instruction of a translation table is a 
label variable, it judges whether the label and branching place of the 3rd operand of the 
bne instruction in an assembly code are the same. Since both sides have branched to the 
mfc2 instruction in the case of this example, it is in agreement. Since it was altogether in 
agreement with the instruction sequence of a translation table, the instruction sequence 
in an assembly code is transposed to a sleep instruction according to the format to 
which it was given by Sformat. Since imml is a variable in the case of this example, 
"0x0003" substituted at the time of comparison of an andi instruction is used. 
[0081] Thus, with this operation gestalt, since the instruction sequence which was a 
waiting routine for a hardware module processing end in the conventional program can 
be automatically transposed to a sleep instruction, the effort of the part and a 
programmer is decreased and it becomes possible to attain the increase in efficiency of 
the low-power design in a system LSI. 
[0082] 

[Effect of the Invention] It becomes possible to attain low-power-ization, avoiding the 
degradation by execution of useless sleep according to the system LSI which is invention 
according to claim 1 to 4, since a halt (sleep) of the clock supply to CPU is controllable 
by software (sleep instruction), as explained to the detail above. Furthermore, it 
becomes possible by controlling resumption (Wake rise) of the clock supply to CPU by 
hardware to raise a low-power-ized effect sharply, being able to carry out the sleep only 
of the suitable period and avoiding the degradation by execution of useless sleep without 
predicting a sleep period. Moreover, since the power management equipment which 
realizes these functions can be mounted by very easy hardware, its overhead of the area 
by this and power consumption is also small. Moreover, since the real line count of an 
instruction becomes less than the conventional program by transposing the waiting 
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routine for a hardware module processing end which exists in the conventional program 
to one sleep instruction, the power consumption by memory access is also reducible. 
Furthermore, since two or more instructions are transposed to one instruction, the 
amount of memory which is needed since a program is stored also becomes small. 
[0083] According to the system LSI which is invention according to claim 5, a sleep 
instruction 
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±fc<J:0, >y- K$»T*S>:*-jI,M0. M2<Z>fcM** 
7£f$oRI1t*CPU 1 1 £X»J-:73tt&o cniCJro 

[0025] 'f7--**i>j«>l»*^*-Jl,2 

OR h 2 5*C'M?ntt^ 0 
[0026] X y-^WSIl:* »; 77 o ■> 7244*. C 
PU 1 \^<OS>u? ?<»i*i$i&fflW?Z>Ult><D? 'J y-7 
7D^7t^f). CPUl 1^^-fe^ HS^STF^ 
30 *fc3>/<u-*2 I*6'i-b» hfi^RTF^A^^ 

[0027] OR y- h 2 5<DA*«. * U -^SiJiai^ 
»J ?:/7O?^2 4<DtfJ*>0UTi. «^>X^L 
S 1©»^-C'CPU 1 U£m&£tlXi t *tci>a?t>CK 

mr y j* 4 1> * a y * -C*D, tfiA^CPU 

1 l^^n^^D^CLKi^t^o ^^^.-jUtt 
!S77i/^^2 3ti. Y0*7±V>*.->V<7>n 
KSft ft AT * ^<?> b i> A ^? 0 , »m - K * 

40 %>X*<!NIL\Z. CPU 1 l^ir^ hL. ft/\-K->*T 

xmsiocpui i*«^oftittftwr*^^* 

fttSftW^U^A^-C'^D. CPUl l^AU-^ 
ft^n-K/^tf-r^i^tefelftiacoejSftfT^* 3> 
/^-i>2 1«. CPUl l^-)xOT?75^^ 

50 77^^5?23<Dil. ^x^^^'t^a-^U 
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7 

[0028] *J8*^aR©^Xf t A L S I (DftfHCOt* 
[0029] ttffigtftt, T*fc>* V* ^ L S I & M -br 

- zffflm? i j ^770^24 <j>W2jo ut^ "0" 
cpui n*. A*M-K^*r*^a-*«c«i 

34^ ^<?>m- K£*7*s>*-^te#j6T*fcr* F 

[0030] »J fr^X!??* <h , * '/ 

F#©^W J>7 ?7^V*-^7 * -*fv 

h^e^^-;U2 0©$*4*7 5>7'-t^»-^ 
U^^22i3>^*U-?2 1 tcf£i£3n&. 

a 'j -7"s«si7 'j?77o^7 2 4 v h sn. -eo 

£B7J0UT** " 1 " 

[0 03 1] OR K 2 50A^<D 1 r>X'3b*Z V - 
7"fclffll7 ^7P ?72 4e>tf3^0UT:tf " 1 " £fc 
ORy-h2 50tii*, -*fr*>*>, CPUI 1^ 
Wp^^CLK^. :fr#A;^r'£*^> 
*o ? ^CKatfcmfefer, - l" £fr£o -7*0, 
CPU 1 l^P? * CLK<Dt*iS#f£lh ShfcCi 

cc£*<je>t\ cpui u**'j-7"tt&±fr&. 

[0 032] F0*T*S*»-*MO^*M4W:,, 
#*6nfc®I#it$TT££> *V*-;M*5fe7^yu 

jH*&7 7yi/^^2 3i'?x^^7^7*i>^-^ 
1x^**2 2<2f8££^KW32bT:fc0. ^0>tSHI^ 
A'J-7'^:3-F<>>£tft7 -f-A, KCOt?iM.6nfc 
&f**S»acfc«'&^, * 'J -7 - Wfll7 y 77 a 9 7 

^m^BR^A^snte^t*, it^mtc^frfc-r 

H-fe? KI^RTF^JB^T^o 
[0033] * l J -7"WIBI7 U ? 7" 7 P ? 7" 2 4 # »J -b 
^h^n-Si. C^7^7 > 7D^2 4<DS3^0UT 
j>*"0" <tfr*:teJ5&, OR ; /- h 2 5^4>^—7CD7^ 
r^^^o^CK^ 0Ry-h25Oiti^C 

LKW(Oi$£^$n^ cntc^r, cpui i 

^<D?a ■? *CLK<*&te*WI<**v CPUI 1^0 
[0034] @6tC^f <fc5fr, 3*?©m- F^xT^fc 
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(5) 1M 2 0 0 0 - 1 1 2 5 8 5 

8 

[0 03 5] 07 ti, *ffltt:fcl*&^'7--^*;^> h 
*^>^-jU2 Ol^iD^V^^-^2 1 CD^^^^^-risl 
SBI3T'<2b£o CCX\ K-7*T*r^3.-JUM0, M 

1, M2tC#ltr*- ! e^*-iH*S87^yu^5r2 3 
JWl*.4>?? ?7"^V*-;UU</*#2 2fl>Str> h 

-en-en <so, si, S2) w(wo, wi, 

W2 > t? (SO, Si, S 2 ) ***** " 1 " <7><t 

10 m^X'tbhC tZfnU (W0 , W 1 , W2 ) ttifc* 

f * ^ ^ 7 > 7 ^ 3 . - ^ i I f $ n^c C i 

[0 03 6] CPUI 1WA-F^i7^>-JIM 
liC^OWl^lii^^i, (SO, SI. s 
2) = (1, 0, 0) <t££o A-K-5i7^ 

^^^-jUM2ec^s^^as$n*i, <so, s 

1, S2) = ( 1, 0, 1 ) tteZ>. -€:<t>^, m-F-? 

20 x7^a-^M0iM2 comi5<j>mm% i £ x- c p u 

1 1 *^y-^S-li*@8©Ay-^»^r3-F/ 
UtT^n^i. *-*\ <W0, VI, W2) 

0. 1 ) i>\ 3>/<U-3?2 HCAND^^T 

[0037] >l V -^Mai7 «J ^7*7 D-^24 

cc-b* hft-^STF^ATj^n^ciiCct^r. cpu 

1 i^'J-7*tf3«if^ 3>m*u-^2 lrtTii, 

(SO, SI. S 2 ) £ ( W0 , VI, W2 ) <£>fS* s *l 
-^tMsBS ( A N D^frT^n ? 2 1 a , OR^tt7'D > 

30 i?2 i b) tc<fc^r^^nrc^ # ^»j-7tfb^ocj: 

1 ctCcfc^-CAND^^P ^^2 1 a 4>tttt)7!ftlt 
4R^n^>o 

[0 03 8] AND^fr7'o > i?2 1 a t?ti, ^e^3.- 
^77^U^^23i^x^>7^ 7-^^^-JU 

1. ^^^?2 2cr>^- KfJ<W*-*M0, Ml, M 
2K«lBr&b'^ -etienNAND^- h AC 
0. AC1, AC2tCA733n£o (SO, SI. S 

2 > = ( 1 , 0, 1 > % (WO, VI. V2) = ( 1 , 
40 0. 1 >^*«, N A N D y— H A C 0 , AC 1 , A 

C2c5ffi^(*. ^n-en ~o~ , "i", "0" x&z 

^ti "0" i*** VI =()-C*>^6, S l<Z>0h?£ 

fo *r*^*-^M i osw^«mtcrat>6'r, 

N AND y— h AC l^>til7J(i^tC "1" tte*. ft* 
t>%. 0~4?T>^*t>*~-)\,tlsX^Ztltc>>>- 
n^7^^.- *4>ttfEttttK W^AN D y— h A C 

3<^>ai^tc?^-r^o 

[0 03 9 3 ^- F^^T^^^^MO^^fl^T 
50 b. S0 = 0^oT, N A N D y— h A C 0 <D\btfyft> 
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-l"i*-*T*, NANDy- Y AC2<»ftJj& 
"0" X'$>Z>*>*>, ANDy- h AC Soffit* "0" 

7L. S2 = 0±fr*<t. NANDy-hAC2©aS* 

NANDy-UCO, ACl, AC 
2±^<?>ai^ "I" AND^hAC30 
"1" ANDy- h AC3<Daj^^^ 

2 i coaj^?, -r&fefcij-fe? Mf4RTF±fr*<z>x\ 

m- KO*T^^*-^MOiM2COr5*C>^fI^T 
U-fe? MI^RTFtCjr^t, XU-:flMa7!J ^7 
fr£<b* ? *CKOtg#. ORy-h250 

awc^^aitr&sn, cpui i^^d-^cl 20 
[0 04 0] /wF9xr*s>»-Ji'M0**i» 

[0 04 1 ] ^'J-7^J:or. 0R&fr#fg*<* 
xOr77t^-;H.^^2 2©M0, Ml, M 

zvm&?z>v? m*, -tti-enANDywoco, 30 

OC1, OC2KA^£ft-5o fe^L,- *2^»-*«Sl 
7^u^x*2 3<Di&*. 

(SO, Si, S2) = (1.0, 1 > . (W0, 
Wl, W2> = (1, 0. 1 ) OtZkt. AND ; /- h 

oco, oci, oc 2 -t*ven-o~. 

R ; /- hOCSCDffi^t* "0" Wl =0t'*i 

frh. S 1 0 m- h" xT* - Jl'M 1 (^ft 

fEtt3(crafe*r. ANDy-^oci osa^rt ~o - 

*V OR^hOC3<^m^?;ST^o 
[0 04 2] K x 7*^ » -^M0 OWSaiWT 

U S0 = 0±fc*<t, AND/- hOCO<DU*# 
"1" <b*0. CtUCX^X, ORy-hOC3<0«^ 

4> "1" COfS*5-?;U^7U^^2 1 ciOR 

h2 1 d£iiO-C\ 'Jt^H^RTFil-CXV 

-^HJSl^iJ ^^7D^^2 4tC?4l^5n^o 

[0043] gfli^g^B R*AJ?3 titc*£i&Z. ~?>l 

1 c<7>a3^K^^<ORy-h2 1 d<D 50 
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13132 0 0 0- 1 1 2585 
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tt!*F# " 1 " 0 > A L> -7*«S!7 »J ? 77 0.;7*2 

[0 04 4] CCX'Xt, CPU 1 1£^W *7*7 ;? 

AND^±OR*fto*1?fcjfc£e(iff& 

[0045] IStO^-K^xr^^a-^ 
St$7KJ:^T. CPU1 lft^x^irT^S^ 

*>CPU 1 1 ^7^7 3i*^>tg^-tC(i. nw? 

U-^21, ^*^?T-;7'ty 3 .-^U*/A^22 > 

*IMBR<DOR«#<DIS**y-te* Mf^-RTFib 

[0 04 6 ] f0ft*fKBR3»A^£ft&<b, 
MM? 'J ^77a^724aor'J«fe ? Ht-^RTF 

BliCCPUl 1 £0W*7 >7 31*^Ci^BJS6i^ 

*MAtfi«*<DflWtt:a ~> fc t Zicc P 

[0047] tmWfltrtit, fit^^Ar A L S I K 
/ f 7 - * V* > h * s> * - * 2 0 £ £10 O fc m EfcTift 

tg&fe£CPUl l<7>*CCg*>T4>J:<,>. C<0^^*, ^ 
^-r^T^*7*^^-jUu^A^22. -t^^-^M^S 

77^^X»2 3^'J-7B«7 »J ?7*7D?7" 

[0048] C © J: 7 CC2|s^a&ffJSS-Ct3t, V7h^*T 

tCcfco-CCPU 1 1 

PU1 1 'J - ^S«M»St4Ci^r 

^5J6fei<f&» S6tc, ^-K^^riCctorCPU 1 
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11 

[0049] tEBWmt««$nt^A:/^ K^~T 
Mm7D^Ai:0^<^^ 5 etc, CPU* 

[0050] [ m 2 *te^ss ] 2 £tts 

BIO, H 1 1 ^CXS 1 2*&WOXWffl?2>. 
[0 05 1 ] 5 F">*T«>»--AMO, M 

1, M2, M3. M4^*7@ I tC^t/fc^X^ALS 

X. J5311. 1. Ml. 2, M2. 1, *5JI2. 

2. J$uftaa3'c v -en-en^- ^xt^^-^m 

0, Ml. M2. M3. M4cttO-CA&WMtt*tt<*n 

<8K*Ka*ft**C±tCJ:^T\ CPU1 
[0052] V*>h, C<DA-*>&. *?fStlfc<&a 
^ - *4>U»'K7'r &<Z> &nr> t><7>X& Z>t?Zt, 

[0053] -ecr, 01 nc^-rig 2 

u^^7-f-^KRG-C^ ab*i^X2* 1 

u^iftfrT ^-^Kcocoffltctasr ^rt sartor 
r. cpu 1 1 <do*4>?7 ??*wmz>. 

[0 05 4] *ec, cw^-rw^T. CPU 

1 1 ^^U-^^JStC'T'S^^S 1 2<P^P-^ 
[0055] U^^7 i-^KRGT'fttSnfcuy 

^-^KWUtCtlS-r*<i-f*o AfJ-^f 
[0 05 6] m\ 2tC*S<,*Xs XiJ-TttfEKflfl 
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(7) ^2 0 0 0-1 12 585 

12 

t>^fes^f 5 mic > r r 8 j r 0 x 0 0 0 0 j 

tC. Tr8 J <Z>fii<t r 0 x 0 0 0 1 J 5:ORgfJ^ 
^. PWMC, JSfll. 2. &JI2. 1. *OT2. 2, £ 

2. M3, M4K«Bfr4*£ttCfc«tt:, r r 8 j 

i r o x o o o 2 j . r o x o o o 4 j , roxooo 
8j. roxooioj i©OR?^^-en-entft^ 

10 -£(Dtem£ r r 8 J octetrtL,Tfc<, *fr7v-^KC 

K. AND&l*«t6« TOxOO 00J , OR£fttt& 
f 0x8000 J i r r 8 J <i(DOR^#^-etl-eWf 

[0057] C<Z>J: ^ccf -SC^tcJc^T, m«T, « 
SI. 1, 4M2. AND*ttt?CPUl 1 

rOxO 0 1 5 J KO^^^-^MO 
tM2<^)AND*frcci:-7T, CPUl l^-?Wi?T 
20 y zf£ 1* h t «, X M - ^aff&ftHT & C 4 * 

[0 05 8] fc4* 

£\ CPU 1 1 -CQ«tffi-C^-ty 1 2KT*-te*-r£*g 

CPU 1 l^fe<9r*^*R^Ufc»K&& 

■e©«*tctt. ^u-7^^>ptc^f^<j>NOP^ 
30. fistv&ct^-r^o 

[0059] ±123? 1 ae>'39S*fe«SftCffll*6 

CPUl HCMT^^'J-7W)x>f^7?7 

OT^^Ht^W*, HI 1 3©^ D-^ + - h «:#P.5or 
[0060 ] $ r\ CPUl 1 ^X^^rT^^^^r 

3-h"o (A^?7$i i ) , -en^. cpui i 

*&^^n^, cpui l^^^-f^T^ 

k. cpui i ^i?D y ?o>m&*:te±2i*zm^& 

3ts£5n, c<^fi^tcj:->xcpu i l^y-^-r* 

14), 

[0 0 6 1 ] CPU 1 l*sxij-:?ls'Cl**ittE. *>^> 

i^ccpui i ^o>*a? zmt&mmzi* 
50 n-cc^nt^ cpu i \^<oi?o ? tv&te&nmzi* 
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[ 17) C 

[0062] ( so %m?s] ±e* i VLvm-mste 

* -e c p u i i tfrxemmz&n a c *»t * 
r. CPU l l £v7 1^*7 fcrj:^ 

: Q»f»7fi-9ti:J:<?'CCPU 1 1 *7 -;7'3 

r^^a-^^^stiTfi-^tCcfc^rcpu i i £ 

i ^cfc^i:^- f$*t*^-ju«ri7#%*-* 

* ~ jwot»t a * ju - * > *sra^ y - v&ktc s ft 

[006 4 ] mi Alts ^fALS I<3>7*Dy5AtC 
F-**T*5>»-A*m*Tf*fcJl>-*>© 

[0065 ] Rgtcfc^-c. **\ m f c J: -? 
T. FCun^-^ttiu^^ state 
©fflfciHJBu^** r 2 ten- FT CCT\ ttsfcu 
^>stat e0)§t'? hit, jfttT&»-~ F^*T 

*5>*-A3!«ani**fT+T*n» " i " , **Ji£**7 

UX^ttlt "0~ 

[0 06 6 ] KKand i -»T D- F LfciS 

> FjW r o x 0 0 0 3 J ttftus'x * $ t 

a t eO&Obr? ^ <LSB> ±311 tr? t-cfttl&r* 

?*> 4>fMft£&0*6R9ttSGtv& o -eor. bn 
o*o, c^-^xj, /x- F->*r*s>*-ji> 

M0. M l<Di5*C!>^a^7f ^cr>^»OJU-^>i 
[0067] %tc % CO*-?><rX!J-:/4*ti:B& 
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m &M2 0 0 0-1 12 585 

14 

[0 06 8] #t5to*£&«. M-K'JjtT^-AM 
0. Ml<WafI®U7CCJ:-7X", CPU1 l£^*«f 2 

»^*ya-jif?^-AFwui*, roxooosj i 

*fc, a- *7*«>a-AM0 & M 1 OH 
~h. 0*0 0 * >C 9Tv zf**s*-*,y pwur 
iS* t> fc^r ^ - F 3 * 7 -fc V> 3. - jumlo^skt o 

fc6. CPU1 llr'Jx^^r^ySWOt 1 . *#:7 
10 -f-^KCO^iliANDSittt*^ Utc&iX. ft* 

•c. ^y-^ , »*** , T3r-^3-F0p* "i i i i i 

1" . &F7 <-Jl>FCO0ttl*, AND 

"0" , ORfttt^ "i" i-r^o 

[0 06 9 ] F£*7*^^MOT**7f#*3;U- 

^tc^o ^**&;W*d<l*u^;**s t a t e<7>il 

-*M0, M 1 W^^M^7l/'Cl i ^»ii^ 
t*. Mt^AfiU ^7*Cl'fc^. ^-F 

fe. CWl'-fXt K^*7*^3.-;UM0*fe 

tiM i ^^rn*^^a^«7^&©t«#ofca&oju- 

Hi 7iC^cfc^K!Ja*o cc-c, 0 
*4 ?T ?f*z>* — hz* <-;U FWU<?>iit*. F 
30 * 7^* -;Msi 0 S^M 1 r 0 x 0 0 0 3 J 

&fr7 FCOli, 

;uM0*fci*M i o^*rn^<?><?ji : ii^7*r^^"CC p 

Ul l^y-^^SOt OR*fl=i&^. 
[0 07 0] ro>W5Ktet't\ CCOir^tf^^^I 

[0071] /wF-)xrt^*-ji«aR7» 
40 o^^t, m i e^^m i Q^jno-ciiwr^. 

[0072]Bl8O7O-^*-h«:t)^r. 
y-^a- F^^V/W^tCJ:-?!:. 7t>7'j3-K 

ccxMrr^ (^f ?7$2 i > p cti&? oi* 

S22),», S:mOfc7-lr>^';3- K^7-b> 
7'mciicJ:^'C, ^■i-^'M^dCrtMAB^ 
f&trZ (Ar^7'S23 > ♦ 

[0073 ] ^f^7S2 2t'07 iAr**)>yiC\t. 
50 SSft^-^Uf:^^^ XiftT'-^Jl'tt, M-K^*T 
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15 

J:^"C&31T -5* Hi 9£. Hi 4 £01 

[0074] mi 9tcfei^r, £-r. ae»±*»©*» 

£tT5<> C CtU Sconst «T©$ tate, r 

0. and, o r*ttt*0, SvarHTOreff 

1. re fir 2. imml. i mm2ft9Eft'C<fe&« SI 10 
a be I KTO LABEL 1 £ L A B E 2 It, #iK$fc** 

i»f $tablei$endtab!er 

■*ftfc**^Xl!^~:r*o*sto*^ c©*o$ 

s t r e a aaT»*4»5ll, Sformat UTWft 
[0075] 7<^'J>y©fftafK^r 

*£&hrr&. cork. SBft7'-^in?**iLr# 
iL"c^x^n*cc^*^-7>F^*. «eo&&£Js^ 

rtf 5SfcjOtb$*Of£tC. 7-b>^'Jn- fo^^o 

Tt>yy-3-K*©M»lt. Sf o 
rata t "C#* *>nfc, * 'J — + — -7 * ^ tc 

[0076] WT, **r*>^»Ja- K4KCB 1 4 tc 
witM:-**"- F$~T*s^-;U«If*fcjU-*>*s 

[0 07 7] 7*>^J3- K+CC TLA BEL 1 : J 
ftHRtlfcOT 1 . CO^4-O<&a&tStfl0rfc<. * 
cc. oifc2»^0. gBft7-:/**0* 
^fc9JOgfiW>fr<&±— ST 2><OV. -tO*^>FO 

tts*£?T% aft^-^*o>m f c 2d^o* l 40 

F**r e g l &i**Xttt l Jb**'6. CMC r-fe 
>r>j3- F+Om f c2*4W>»l FOilr 
2msn*. £1)17— TUOm f c2<fo<£Of£2=f 

[0078] mf c*4H*3h*«9>F%— SfcT<SOT\ 
*Oi^Ott3S£?T^o S^i £>a n d i 
*OT\ »l*^5>FOtt«frMT$. jtft-f—r^O 
audi a><£0^ 1 Flt&tfc r e fir 2 *OT\ 

CftKT-fe 'J 3- F^and i ^©Sl 
>Kr2m^o 50 
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16 

[0079] kfc^-^Oa n d i fe*o*2 ^ 5 
> K fiHHUOr e fir 1 ftttCO&fttcftA 
bfc r 2 gtS^-CttAS?*, 513 * ^ > KOtbtfrC 
It. i mill 1 IC TO x 0 0 0 3 J *KAtd*t&, *0 b 
n e fr^Ott*Wt, »2 * ^ ^ > F * V\Mt&V*> 

[0080] SBft^-^Ob n e ^WM3 > 
FO LA BEL II*, ?^*ftlfcr*&3!t»&, 7H2>:7 
Ma- K+©b n e^%©»3*^^> FO?^*±» 

- F4io<-o4i<f»Jfe744:. Sformat V^Xhtitc 

~7*-^y h J£ ft ^ ~C A 'J — ~7'&<£l£ jg 5? tgiZ. h . CO 

«©«£\ i mm 1 fts£ft-C*&*>6. a n d i ft*4> 

tbttoitccK^dnfc r o x o o o 3 j #ffl^*>tt* 0 
[0081] cojt^k. *jas^-ci*, a*©7o 
F>5*r*i?3L-JnaJW7»<5^-^ 

&cwc**©i:\ ^o#, 7P^^^^)W 

[0082] 

[ ftWM ) tLhMOfc IW O fc <fc ^ tc % IS*IS 1 71 

siB^4iaseo^'c^-5vxTALS i ccctntt, 

F$*r tcJ:-»tCPUK:«t& 
£or\ fttttt ^ »J -^©JKff (c-j: *tt«6«T*iiW^ 
F^^rtCiro-CCPUic^T^^o ? ^^oms 

- F^^r^^^-^fflRTIS^-^V* I -wa 

fcis^tc^S i * ^ ■€ 'J S £/h 5 < ^ -5 o 
[0083] tt#3f 5Satt0^mt?«^VA^AL$ I 

»ll/cU^^^ti^2a)7 f-JlF^L, 
9-7*^^hMli. IHU^2©7^-^K(Drt 
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20 



30 



17 

<£iki£2nte<,>£'?tem£x*>^x4>. CPUirWI> 
[0084] iS5j^6i^)*mr^^VA^ALS I 

[0086] * tc* Igto^rm^nrt^c^- K 
[lafficDis^Ai^] 

[01 ] t^HMS(C^^tALS \<0 

[(32] xy-:f**a-F<Mirt**?Br**. 
[133] xy-:*M*a- K0JUtffifiMtfl**?B'C 
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